



FIG. 2



FIG. 3



FIG. 4

**C** 250

| Design-to-Hardware-Description Translation |                                                         |
|--------------------------------------------|---------------------------------------------------------|
| 252                                        | Perform necessary design-wide work on high-level blocks |
| 254                                        | Prepare implementers                                    |
| 256                                        | $b_h := \text{top block of the HLMS design}$            |
| 258                                        | Compile (b <sub>h</sub> )                               |
| 260                                        | Complete all pending work in the implementers           |

## FIG. 5

**280** Compile  $(b_h)$ Allocate memory for a compiler block 282 Translate  $b_h$  into appropriate type of compiler block,  $b_k$ 284 If  $b_h$  has sub-blocks then 286 For each sub-block, b, 288 Compile  $(b_i)$ 290 292 Implement  $b_k$  using the appropriate implementer Save a lightweight description of the HDL implementation of  $\boldsymbol{b}_k$  in association with 294 the parent block of  $b_k$ Free the memory of the compiler block  $\boldsymbol{b}_{k}$ 296 298 Return

FIG. 6





FIG. 8